## مهلت تحویل ساعت ۲۴ روز جمعه ۳۱ فروردین

تمرین چهار – مسیر داده

## به موارد زیر توجه کنید:

۱- حتما نام و شماره دانشجویی خود را روی پاسخنامه بنویسید.

۲- کل پاسخ تمرینات را در قالب یک فایل pdf با شماره دانشجویی خود نام گذاری کرده در سامانه CW بارگذاری کنید.

۳- این تمرین ۶۰ نمره دارد که معادل ۶٫۶ نمره از نمره کلی درس است.

۴- در صورت مشاهده هر گونه مشابهت نامتعارف هر دو (یا چند) نفر کل نمره این تمرین را از دست خواهند داد.

۱- (۲۰ نمره) فرض کنید میخواهیم دستورات مقابل را روی معماری شکل زیر اجرا کنیم.

a: 0xAC620014 b: 0x0082082A

الف- كد اسمبلي معادل هر دستور را مشخص كنيد.

ب- خروجي واحد عمليات sign-extend دستور a و خروجي واحد عمليات Shift left 2 دستور b را مشخص كنيد.

ج- مقادیر ورودی واحد کنترل ALU را برای هر دستور مشخص کنید.

د- مقدار جدید PC پس از اجرای هر دستور چند خواهد بود؟ مسیری را که این مقادیر از آن به دست می آید مشخص کنید.

فرض کنید مقادیر تمام خانههای حافظه صفر است. همچنین در زمان ابتدای اجرای هر دستور، مقادیر داخل ثباتها به صورت زیر است. برای دستورات a و b به طور جداگانه به سوالات زیر پاسخ دهید.

|   | R0 | R1  | R2   | <b>R3</b> | R4  | R5 | <b>R6</b> | R8 | R12 | R31 |
|---|----|-----|------|-----------|-----|----|-----------|----|-----|-----|
| a | 0  | -1  | 2    | -3        | -4  | 10 | 6         | 8  | 2   | -16 |
| b | 0  | 256 | -128 | 19        | -32 | 13 | -6        | -1 | 16  | -2  |

ه- مقادیر خروجی هر کدام از مالتی پلکسرهای این معماری در زمان اجرای این دستورات را مشخص کنید.

و- ورودیهای ALU و دو واحد Add داخل معماری را مشخص کنید.

ز- مقادیر ورودیهای مختلف Register File (شامل Register File (شامل Register File) و Write Data ،Write Register ،Read Register 2 ،Read Register 1 و (RegWrite مخص کنید.



۲- (۲۰ نمره) فرض کنید بخواهیم دستور forr را به میپس اضافه کنیم، این دستور به این شکل کار می کند که محتوای Rt را از Rs کم
کرده و نتیجه را در Rs مینویسد و اگر حاصل صفر نبود به صورت نسبی به مقدار ثابتی که در دستور است پرش می کند.
الف- این دستور از چه نوعی است؟

ب- شکل سوال قبل و جداول زیر را طوری تغییر دهید که امکان اجرای این دستور را داشته باشیم.

| Instruction opcode | ALUOp | Instruction operation | Funct field | Desired<br>ALU action | ALU control<br>input |
|--------------------|-------|-----------------------|-------------|-----------------------|----------------------|
| LW                 | 00    | load word             | XXXXXX      | add                   | 0010                 |
| SW                 | 00    | store word            | XXXXXX      | add                   | 0010                 |
| Branch equal       | 01    | branch equal          | XXXXXX      | subtract              | 0110                 |
| R-type             | 10    | add                   | 100000      | add                   | 0010                 |
| R-type             | 10    | subtract              | 100010      | subtract              | 0110                 |
| R-type             | 10    | AND                   | 100100      | and                   | 0000                 |
| R-type             | 10    | OR                    | 100101      | or                    | 0001                 |
| R-type             | 10    | set on less than      | 101010      | set on less than      | 0111                 |

|             |        |               | Memto- | Reg   | Mem  | Mem   |        |        |       |
|-------------|--------|---------------|--------|-------|------|-------|--------|--------|-------|
| Instruction | RegDst | <b>ALUSrc</b> | Reg    | Write | Read | Write | Branch | ALUOp1 | ALUp0 |
| R-format    | 1      | 0             | 0      | 1     | 0    | 0     | 0      | 1      | 0     |
| lw          | 0      | 1             | 1      | 1     | 1    | 0     | 0      | 0      | 0     |
| sw          | X      | 1             | X      | 0     | 0    | 1     | 0      | 0      | 0     |
| beq         | X      | 0             | X      | 0     | 0    | 0     | 1      | 0      | 1     |

۳- (۱۰ نمره) در مدار های مجتمع، گاهی نقصهای موجود در سیلیکون باعث گیر کردن مقدار یک سیگنال روی صفر یا یک میشود. در هر مورد توضیح دهید با گیر کردن سیگنال، اجرای کدام دستورات دچار مشکل خواهند شد؟ توضیح دهید.

الف- سيگنال RegDst روى مقدار صفر گير كند.

ب- سیگنال ALUop0 روی مقدار یک گیر کند.

ج- سیگنال RegWrite متصل به فایل ثبات روی مقدار صفر گیر کند.

۴- (۱۰ نمره) تاخیرهای زیر را برای بخشهای مختلف شکل سوال یک در نظر بگیرید:

| I-Mem | Add  | Mux  | ALU  | Regs | D-Mem | Control |
|-------|------|------|------|------|-------|---------|
| 220ps | 75ps | 20ps | 95ps | 70ps | 240ps | 45ps    |

فرض کنید ۸٪ دستورات از نوع پرش غیرشرطی، ۱۱٪ پرش شرطی، ۱۶٪ از نوع store و بقیه R-type هستند. در صورتی که با تغییراتی بتوان تاخیر ALU را به ۸۵ و تاخیر D-Mem را به ۱۸۰ پیکوثانیه کاهش داد، و تاخیر کنترل به ۵۵ پیکوثانیه برسد، میزان تسریع چقدر خواهد بود؟ (تاخیرها را برای نوشتن و خواندن برابر مقدارهای گفته شده در نظر بگیرید، تاخیر بخشهای دیگر را ناچیز فرض کنید.)